{% extends 'web/layout/basic.html' %}
{% load static %}

{% block title %}用户注册{% endblock %}


{% block css %}
    <link rel="stylesheet" href="{% static 'web/css/account.css' %}">
    <style>
        .error-msg {
            color: red;
            position: absolute;
            size: 13px;
        }
    </style>
{% endblock %}


{% block content %}
    <div class="account">
        <div class="title">用户注册</div>
        <form id="regForm" method="post" novalidate>
            {% csrf_token %}
            {% for field in form %}
                {% if field.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="row">
                            <div class="col-xs-7">
                                {{ field }}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-xs-5">
                                <input id="btnSms" type="button" value="点击获取验证码" class="btn btn-default">
                            </div>
                        </div>

                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}

            <div class="row">
                <div class="col-xs-3">
                    <input id="btnSubmit" type="button" class="btn btn-primary" value="注册"/>
                </div>
            </div>

        </form>
    </div>
{% endblock %}


{% block js %}
    <script>

        // 页面 DOM 加载完成之后执行的函数
        $(function () {
            triggerOnClickBtnSms();
            triggerOnClickBtnSubmit();
        });

        /*
        点击获取验证码按钮时触发事件
         */
        function triggerOnClickBtnSms() {
            $('#btnSms').click(function () {
                // 清空上次点击产生的 error message
                $('.error-msg').empty();

                // 获取手机号
                let mobilePhone = $('#id_mobile_phone').val();

                // 发送 ajax 请求
                $.ajax({
                    url: "{% url 'web:send_sms' %}",  // 要提交的地址
                    type: 'GET',                      // GET/POST
                    data: {                           // ?key=val
                        mobile_phone: mobilePhone,
                        tpl: "register",
                    },
                    dataType: 'JSON',                 // 将服务端返回的字符串 res 转化为 JSON
                    success: function (res) {         // 请求发送成功时回调
                        if (res.status) {
                            smsTick();
                        } else {
                            // 错误信息
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0]);
                            })
                        }
                    },
                });
            })
        }

        // sms倒计时
        function smsTick() {
            let $smsBtn = $('#btnSms');
            $smsBtn.prop('disabled', true);

            let time = 60;
            let reminder = setInterval(function () {
                $smsBtn.val(time + '秒重新发送');

                time = time - 1;
                if (time < 1) {
                    clearInterval(reminder);
                    $smsBtn.val('点击获取验证码').prop('disabled', false);
                }
            }, 1000);
        }

        // 点击 BtnSubmit 时触发事件
        function triggerOnClickBtnSubmit() {
            $('#btnSubmit').click(function () {
                $('.error-msg').empty();

                $.ajax({
                    url: "{% url 'web:login_sms' %}",
                    type: 'POST',
                    data: $('#regForm').serialize(),  // 收集表单中所有字段的数据 + csrf token
                    dataType: 'JSON',
                    success: function (res) {
                        if (res.status) {
                            location.href = res.data;  // 跳转到 login
                        } else {
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0]);
                            })
                        }
                    },
                })
            });
        }

    </script>
{% endblock %}